package com.example.system.class02;

import java.util.Arrays;

/**
 * @Date 2022/7/17
 * @Created by Jonathan
 */
public class Code02_BubbleSort {
    public static void main(String[] args) {
        int[] arr = new int[]{3, 1, 2, 4};
        bubbleSort(arr);
        System.out.println(Arrays.toString(arr));
    }

    private static void bubbleSort(int[] arr) {
        //一些边界条件的校验
        if (arr == null || arr.length < 2) return;
        // 排序
        for (int i = 0; i < arr.length - 1; i++) {
            boolean flag = false;
            for (int j = 0; j < arr.length - 1 - i; j++) {
                if (arr[j] > arr[j + 1]) {
                    flag = true;
                    swap(arr, j, j + 1);
                }
                // note: 第一轮没有交换过的话说明是有序的 就结束循环
                if (!flag) {
                    break;
                }
            }
        }
    }


    private static void swap(int[] arr, int i, int j) {
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }
}
